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Le marché EL. 


Comment tricher? 


Les programmes de jeux d’échecs sont difficiles à écrire. Mais il est 
possible pour les débutants de construire un jeu simple et « intelligent ». 


Quand les amateurs commencent à écrire leurs 
propres programmes, beaucoup rêvent du jour 
où ils seront capables de programmer un jeu 
d’échecs. Cela ne manque pas, au contraire. Les 
programmes pour ordinateurs domestiques ou 
les machines préprogrammées pour le jeu 
d’échecs abondent. Mais l’écriture d’un jeu 
d’échecs tourne parfois à l’obsession, même 
parmi les programmeurs peu familiarisés avec 
les échecs. Pour expliquer ce phénomène, il faut 
peut-être considérer l’image très intellectuelle 
qu’a ce jeu, ou encore l’idée selon laquelle un 
ordinateur qui joue aux échecs est une machine 
intelligente. Cela dit, il est très difficile de vou- 
loir expliquer comment écrire un programme 
entier de jeu d’échecs. Toutefois, nous pouvons 
donner quelques principes sur lesquels des jeux 
dits « intelligents » mis sur ordinateur sont 
construits, et jusqu’à quel niveau il vous est 
possible d’écrire un programme intéressant en 
BASIC. 

Il convient de ne pas perdre de vue que ces 
jeux n’ont que peu de chose à voir avec les jeux 
d’arcades, d’aventures ou de simulations, qui 
tous demandent des techniques différentes de 


programmation et de l’imagination dans les 
procédures d’adresse. Nous commencerons 
cette analyse des jeux « intelligents » avec un 
exemple que d’aucuns trouveront un peu sim- 
pliste, mais qui a l’avantage de recouvrir la plu- 
part des principes d’écriture de ces jeux. 

Beaucoup de petits (et de grands) enfants 
connaissent le jeu « ciseaux-papier-pierre ». Les 
règles en sont simples : tous les joueurs pensent 
à l’un de ces trois objets, puis doivent présenter 
simultanément la main dans la forme de l’un de 
ces trois objets. Le gagnant est déterminé ainsi : 
les ciseaux gagnent sur le papier (ils coupent), le 
papier sur la pierre (il couvre), la pierre sur les 
ciseaux (ils sont cassés). 

Pour tous ceux qui ont suivi le cours de pro- 
grammation BASIC, cela peut paraître facile 
d’écrire un programme pour faire jouer ainsi 
l’ordinateur. La fonction RND est utilisée pour 
choisir un des éléments du tableau contenant 
« CISEAUX », « PAPIER » et « PIERRE ». L’élément choisi 
est imprimé quand on appuie sur la barre 
d’espace. Le joueur tape selon son choix (le pro- 
gramme dépend de son honnêteté), et le pro- 
gramme détermine le gagnant en comptant les 


Main invisible 

Les machines 
préprogrammées de jeu 
d'échecs contiennent les 
mêmes composants que 
les ordinateurs personnels : 
une unité centrale, une 
RAM et un programme 

en ROM. Seules les 
entrées/sorties diffèrent. 
La machine ci-contre utilise 
un servomécanisme et un 
système magnétique pour 
permettre à l'ordinateur de 
bouger les pions. Quand, 
par exemple, un cavalier 
saute une autre pièce, un 
algorithme compliqué est 
employé pour enlever 
l'obstacle et le remplacer 
par la suite. 

(CI. lan McKinnell/ 

Milton Bradley.) 
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points marqués par l’ordinateur et son adver- 
saire. Si la fonction RND est vraiment aléatoire, 
les totaux des points marqués de part et d’autre 
devraient s’équilibrer dans l’ensemble, quelle 
que soit la stratégie adoptée par le joueur. Or, il 
faut maintenant déterminer comment améliorer 
la stratégie de l’ordinateur pour assurer sa 
victoire. 

Lorsque nous avons étudié les fonctions aléa- 
toires, nous avons appris que générer une 
séquence réellement aléatoire est une tâche 
impossible pour les êtres humains et pour les 
ordinateurs, bien que ces derniers arrivent à 
faire une bien meilleure approximation. Dans 
une longue série de coups, le joueur humain 
choisit invariablement un objet plus souvent 
que les autres. On peut donc inscrire dans le 
programme un sous-programme qui garde en 
mémoire les choix du joueur, en utilisant un 
tableau à trois éléments appelés CHOIX(1) CHOIX(2] et 
CHOIX(31. Chaque fois que le joueur joue un coup, 
on augmente d’un point le total dans la colonne 
correspondant à son choix. L'ordinateur peut 
alors calculer quel objet est le plus souvent joué, 
et ensuite jouer l’objet qui l'emporte sur celui-ci. 


à. 


Trois problèmes se posent avec cette 
méthode. Premièrement, si l’ordinateur joue 
régulièrement le même objet, le joueur va vite 
s’en apercevoir et en profiter. Donc il faut faire 
en sorte que l’ordinateur choisisse entre les trois 
objets en utilisant la fonction RND, mais avec 
l’adjonction d’un sous-programme pour lui 
faire choisir un peu plus souvent l’objet qui 
l’emportera sur le choix préféré du joueur. 

Le deuxième problème est qu’au cours de la 
partie le joueur tend à changer son objet pré- 


féré. Aussi, plutôt que de garder en mémoire 
tous les choix de l’adversaire depuis le début de 
la partie, il vaut mieux que le programme 
n’enregistre que les vingt derniers coups par 
exemple. Cela nécessitera un tableau CHOIX de 
20 x 3 éléments et un sous-programme plus 
sophistiqué pour faire les totaux et préciser le 
meilleur choix pour le prochain coup. 

Le plus grave inconvénient de cet algorithme 
apparaît au moment où le joueur réussit à per- 
cer la stratégie de l’ordinateur. Il lui est alors 
facile de jouer de telle façon que l’ordinateur 
perdra fatalement plus de la moitié des coups 
joués. Le joueur pourrait, par exemple, jouer 
régulièrement le même objet, puis subitement se 
mettre à en jouer un autre, et ainsi de suite. 
Nous avons donc besoin d’un autre algorithme 
qui évite ces problèmes. Néanmoins, cela vau- 
drait la peine de développer des programmes 
capables d’utiliser à la fois la méthode totale- 
ment aléatoire et la méthode aléatoire pondérée, 
puis d’observer les résultats. 

Les êtres humains sont incapables de prendre 
une décision totalement irrationnelle ou aléa- 
toire. Il s’ensuit que chaque choix dépend des 


Position 
gagnante 


Une évaluation correcte 
des positions est 
fondamentale à tout 
programme de jeu 
même si ce jeu est 
aussi simple que le 
morpion. Sur ce tableau 
3 x 3 les zéros du 
joueur sont représentés 
par le chiffre 1, les croix 
de l'ordinateur par le 
chiffre 4. A l’aide de ces 
chiffres, on peut évaluer 
n'importe quelle 
situation de jeu; il suffit 
de faire les totaux pour 
chaque rangée, colonne 
et diagonale. Un total 
de 12 indique que 
l'ordinateur peut donc 
gagner, et ainsi de 
suite. Les valeurs 1 et 4 
sont utilisées parce 
qu'elles fournissent des 
totaux différents pour 
chaque combinaison de 
coups. (CI. Liz Dixon.) 


choix précédents. Si l’ordinateur réussit à élabo- 
rer une approximation sur ces choix, alors il 
devrait pouvoir gagner assez régulièrement. 
Étant donné que chaque joueur possède une 
formule personnelle inconsciente, et qu’elle 
change sans doute au cours d’une longue partie, 
le programme doit être écrit de telle façon qu’il 
puisse interpréter la formule pendant le déroule- 
ment de la partie. Les programmes qui sont 
capables d’apprendre de cette façon s’appellent 
des programmes « heuristiques ». 
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Un programme heuristique permet à l’ordina- 
teur de détecter des changements dans la straté- 
gie de son adversaire et de modifier son algo- 
rithme en conséquence. Un tel programme est 
doté de la possibilité de stocker dans sa 
mémoire, disons les cinquante derniers coups 
joués par les deux adversaires. Il balaie sans 
cesse cet enregistrement des coups précédents, 
appliquant une technique statistique appelée 
« corrélation ». 

L'ordinateur doit faire des centaines de com- 
paraisons entre un choix du joueur et les choix 


précédents. L'ordinateur effectue la même opé-- 


ration sur ses propres choix. Considérons main- 
tenant la corrélation entre le coup du joueur et 
son coup précédent. D’abord nous devons com- 
poser un tableau de 3 X 3 que nous appelons 
CORR1, parce qu’il constitue notre premier test de 
corrélation. Ensuite nous devons examiner 
l'historique de la partie, sur les cinquante 
derniers coups, en donnant le numéro 1 à 
« ciseaux », 2 à « papier » et 3 à « pierre ». Cha- 
que fois que le joueur a choisi pierre (3) après 
ciseaux (1), nous ajoutons un point à l’élément 
CORR111,3) ; lorsque pierre (3) est suivi de papier 
(2), on ajoute un point à CORR1(3,2) et ainsi de 
suite. 1 

Si le joueur fait des choix réellement aléa- 
toires, alors chaque élément de CORR1 devrait 
contenir à peu près le même nombre de points 
— mais il est très peu probable que ce soit le cas. 
Donc, si le dernier choix du joueur était papier, 
alors l’élément de la rangée 2 (papier) de CORRI 
qui a le total le plus fort nous indiquera la meil- 
leure probabilité pour son prochain choix. Plus 
la différence est grande entre les éléments d’une 
rangée, meilleure est la corrélation et plus sûre 
la prédiction. Il est possible cependant que l’on 
trouve peu de corrélation entre le choix du 
joueur et son choix précédent, auquel cas il fau- 
dra effectuer des calculs de corrélation avant 
l’avant-dernier choix, ou entre le choix du 
joueur et le choix précédent de l’ordinateur. 

Il se peut que les divers programmes de corré- 
lation prédisent tous des probabilités différentes 
pour le prochain coup du joueur. Le pro- 
gramme doit alors décider quel est le conseil le 
plus sûr. Pour ce jeu simple, il lui suffit de voir 
lequel des tests donne la corrélation la plus 
forte. Par exemple, le tableau CORR1 pourrait 
donner les possibilités suivantes : ciseaux 51 %, 
papier 29 %, pierre 20 %, tandis que CORR? (qui 
compare le choix du joueur avec le dernier coup 
de l’ordinateur) pourrait donner : ciseaux 24 %, 
papier 60 %, pierre 16 %. Il est évident que 
CORR? a une meilleure corrélation; sa prédiction 
doit être retenue. Un programme de jeu intel- 
ligent comportera souvent plusieurs sous- 
programmes, chacun ayant une stratégie dif- 
férente pour analyser le jeu et conseiller le 
programme principal sur le meilleur coup à 
jouer. Le programme de jeu peut considérer ces 
sous-programmes comme une sorte de « com- 
mission » et suivre les conseils de la majorité. 
Mais, au cours de la partie, il peut décerner des 
points aux sous-programmes qui donnent de 


5 CLS 
10 DIM C1(3,3, C23,3), C313,3) 

26 CR=-0 

30 FOR = 1703 

40 IF CPL) CR THEN BG = LCR = C1PLI) 
50 IF C2IPP CR THEN BG = l:CR = C2(P2,) 
60 1F C31P3,) >CR THEN BG - l:CR - C31P3,1} 
70 NEXTI 
80 CT = BG1 
90 IF BG = 1 THEN CT = 3 

100 GET PT:IF PT = O THEN 100 

110 REM LINE 100 WAITS FOR A DIGIT TO 

120 REM BE PRESSED 

130 IF CT = PT-1 THEN CS = CS + 1 

140 IF CT = PT-2 THEN PS = PS +1 

160 IF CT = PT + 1 THEN PS = PS +1 

160 IF CT = PT + 2 THEN CS = CS +1 

170 CLS 

180 PRINT « YOUR CHOICE : »; PT 

190 PRINT « MY CHOICE : »; CT 

200 PRINT « YOUR SCORE IS »; PS 

210 PRINT « MY SCORE IS »; CS 

220 CAPL,PTI = CHPL,PT) + 1 

230 CAPP,PT) = CAIPP,PTI + 1 

240 C3(P3,PT) = C3IP3,PT) + 1 

250 P3 = PP 

260 PP = PL 

270 PL = PT 

280 GOTO 20 


« bons » conseils pour identifier les plus fiables. 

S’il s’avère qu’il y a effectivement une corré- 
lation entre les coups ou choix du joueur et les 
coups précédents de l’ordinateur, il devient pos- 
sible de programmer un facteur de « bluff » 
pour tromper le joueur, comme dans les jeux 
d’argent. 

Le journal Scientific American a rendu 
compte d’une expérience menée à l’université 
d’État de New York à Buffalo. Plusieurs pro- 
grammes spécialisés dans le poker (tous dotés 
d’une capacité d’apprentissage) furent opposés 
les uns aux autres dans plusieurs milliers de par- 
ties. Le gagnant était un programme appelé 
Adaptive Evaluator of Opponents (Evaluation 
adaptée de l’adversaire), qui effectuait une pre- 
mière évaluation de la force de jeu de ses adver- 
saires, puis modifiait cette évaluation au cours 
de la partie. Le programme Sells and Buys 
Imags (Vend et achète des images) n’a obtenu 
que des résultats médiocres : sa technique était 
de « bluffer » pour « vendre » une image fausse 
à ses adversaires, ou bien d’« acheter » en quel- 
que sorte le style de jeu des autres. 

Le Bayesian Player (Joueur bayésien) utilisait 
des méthodes inductives pour améliorer son jeu 
en comparant les conséquences réelles. Enfin, le 
programme appelé Adaptative Aspiration Level 
(Niveau d’aspiration évolutif) tentait d’imiter 
un trait que l’on croit avoir observé dans le jeu 
humain : l’adaptation du niveau d’aspiration 
(c’est-à-dire le degré de risque que l’on accepte 
de courir) selon les résultats passés et la situa- 
tion actuelle. 


Apprenti sorcier 

Ce programme conçu pour 
le jeu ciseaux-papier-pierre 
montre comment on peut 

« apprendre » au cours 
d'une partie. L'ordinateur 
sélectionne parmi les 
chiffres 1, 2 et 3, compare 
son choix avec celui que 
vous venez de taper et 
compte un point au 
gagnant. L'instruction GET 
est utilisée pour vous 
permettre de frapper les 
trois touches numériques 
très rapidement. Si vous 
jouez vraiment au hasard, 
vous devez vous apercevoir 
qu’au bout de quelque 

200 coups l'ordinateur 
commence à vous 
distancer. Il est possible de 
tromper ce programme et 
de continuer à gagner, mais 
des sous-programmes plus 
sophistiqués peuvent être 
ajoutés pour vous 
empêcher de réussir. 
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Topographie 


Les langages évolués, tel le BASIC, gèrent automatiquement 
la mémoire. Quand ce n’est pas le cas, il nous faut un relevé détaillé 
de la mémoire afin de nous y retrouver. 


L'unité centrale de l’ordinateur possède une 
capacité d’adressage dont la taille détermine le 
nombre de positions mémoire possibles. Pour la 
plupart des micro-ordinateurs, cette capacité 
mémoire est de 64 K. La mémoire doit compor- 
ter la mémoire vive et la mémoire morte propres 
à la machine (RAM et ROM), leurs exten- 
sions éventuelles ainsi que l’adressage des com- 
posants et des ports d’interface. Ces derniers 
étant considérés également comme positions 
mémoire. La table mémoire constitue une des 
parties les plus importantes de l’ordinateur. Il 


Mémoire système 

Un micro-ordinateur de 4 K 
de capacité RAM ne 
comportera le plus souvent 
que 3 K de mémoire 
utilisateur (programme). 

La différence ou réserve 
machine sert au système 
d'exploitation lorsque la 
machine est allumée. Elle 
est utilisée pour stocker des 
variables système (telles que 
les valeurs provisoires lors 
des calculs d'expression 
complexes) et aux pointeurs 
ou chapeaux indiquant les 
diverses positions de 


s’agit de la liste des positions mémoire affectées données en mémoire. 


HAE OE 


aux différentes fonctions et représentées par un 
diagramme. Si vous programmez seulement en 
BASIC, cela ne vous intéresse pas. En revanche, 
si vous souhaitez travailler en langage machine 
ou si vous désirez construire vous-même des 
extensions supplémentaires, cela est essentiel. 
Nous exposons ici le contenu caractéristique 
d’une table mémoire. Notre exemple se rappro- 
che davantage d’un système fondé sur un 6502 
que d’un Z80, mais les grandes lignes sont les 
mêmes. Les constructeurs ne communiquent 
pas tous la conception de leur table mémoire, 
mais des utilisateurs le font souvent à leur place. 
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Pile 

Cette portion de la mémoire 
est réservée à l'unité 
centrale et est organisée 
selon le principe LIFO : 
dernière information entrée, 
première sortie. Un octet 
peut être soit empilé soit 
dépilé. Lors de l'exécution 
d'une routine GOSUB en BASIC 
par exemple, l’'UC empile 
l'adresse mémoire de 
destination finale (RETURN). 
La pile est très utilisée pour 
l'évaluation d'expressions 
arithmétiques, et pour des 
boucles de type FOR..NEXT. 


RAM utilisateur 

Sa taille détermine le niveau 
de complexité possible des 
programmes que vous 
pouvez utiliser. C'est un des 
critères fondamentaux pour 
le choix d’un micro- 
ordinateur. 


Tampons 

Un emplacement mémoire 
doit être prévu pour 
préserver les caractères 
frappés au clavier que le 
programme ne peut traiter 
immédiatement. Un tampon 
cassette est également 
nécessaire car la plupart des 
systèmes d'exploitation 
écrivent les données par 
blocs entiers avant de les 
transmettre. 


Mémoire disponible 

La table mémoire doit 
comporter de la place pour 
les extensions mémoire vive. 
Certains systèmes 
autorisent 64 K d'ajout, mais 
il s’agit dans ce cas d’un 
dispositif d'acquisition de 
données qui intègre à 


volonté la partie désirée de 


la mémoire vive, à la table 
mémoire. 


Chaînes de caractères 

Si le BASIC propre à votre 
ordinateur exige de vous que 
vous spécifiez à l'avance 

la longueur de toutes les 
chaînes, elles seront 
stockées dans une table 
mémoire comme des 
variables dimensionnées. Si 
au contraire il accepte des 
chaînes de type dynamique, 
susceptibles de varier en 
longueur, alors les données 
seront stockées séparément 
en une zone mémoire 
changeant constamment de 
taille. Régulièrement, le 
système d'exploitation 

« nettoiera » la zone 
mémoire de la pile en 
supprimant les données 
devenues inutiles. 


l | 
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RAM système 

Certains ordinateurs 
comportent une RAM 
système distincte de la RAM 
utilisateur. Elle est 
généralement destinée à 

la RAM écran (pour laquelle 
chaque octet correspond à 
une position sur l'écran) 

et à la RAM couleur (pour 
laquelle un octet donne 

la couleur d'écriture et la 
couleur de fond). Les 
ordinateurs dotés de 
capacités graphiques 
multiples et à haute 
résolution nécessiteront 
beaucoup de RAM 
utilisateur, ce qui aura pour 
conséquence de surcharger 
la mémoire système. Ainsi, 
dans un programme de jeu, 
la partie graphique 
représentera la plus grande 
partie des besoins mémoire. 


Contrôleur vidéo 

Les modes graphiques les 
plus sophistiqués tels que 
les jeux faisant intervenir 

la résolution graphique 
multimodes sont de plus en 
plus gérés sur le plan 
matériel et non logiciel. La 
table mémoire comportera 
ainsi une douzaine de 
registres environ à un octet 
chacun, qui régiront tous les 
éléments visuels, depuis la 
couleur du fond jusqu'à la 
position exacte de chaque 
plan-objet. 


Mémoire disponible 
Lorsque vous utilisez un 
programme en cartouche, 
il vient figurer dans la table 
mémoire sous la forme 
d’une extension ROM. 
Certaines machines 
disposent d'emplacements 
sur leurs cartes 
électroniques destinés 

à recevoir en mémoire 
morte des langages 
supplémentaires. Ces 
derniers seront également 
chargés dans la table 
mémoire. 


Puces entrée/sortie 

L'UC ne peut communiquer 
qu'avec des organes 
apparaissant dans la table 
mémoire. Ainsi, les ports 
d'interface et les autres 
composants doivent-ils y 
figurer. On trouvera ainsi 

les interfaces pour le clavier, 
le lecteur de cassettes, le 
contrôleur vidéo, et les 
interfaces externes telles 
que l'imprimante. L'UC 
adresse généralement la 
mémoire sous forme de 
blocs (par exemple de 4 K 
chacun). C'est pourquoi les 
puces entrée/sortie occupent 


ROM système 

Dans un ordinateur 
individuel, la ROM sert à 
stocker l'information de 
base. C'est-à-dire, avant tout, 
le système d'exploitation 
constitué de l'ensemble des 
programmes en code 
machine. Ces programmes 
effectuent des fonctions 
telles que le balayage du 
clavier et le stockage ou la 
restitution des données sur 
cassette. || y a également 
l'interpréteur BASIC, qui 
traduit les programmes 
BASIC en instructions 

de base compréhensibles 
par l'UC. 


Contrôleur son 

Le logiciel peut permettre 
d'obtenir des sons 
rudimentaires, mais les sons 
complexes et le contrôle 

du son nécessitent un 
contrôleur son spécifique, 
dont la sortie attaque 

un petit amplificateur. 


en général 4 K de la table 


mémoire. 


PIA (adaptateurs d'interface 
périphérique) 

Ils servent à gérer la plupart 
des interfaçages simples 
avec le clavier, la cassette, 
la manette de jeux et 
l'imprimante. Les puces les 
plus évoluées (tel que 
l'adaptateur d'interface 
multifonctions 6522) sont 
capables de faire des 
conversions entre données 
en parallèle et en série. Ils 
comportent en outre des 
horloges internes utilisables 
pour la programmation ou 
pour le contrôle de la 
vitesse de transmission des 
données. 


Générateur de caractères 
C'est le meilleur exemple 
d'utilisation de la ROM pour 
le stockage de données 
plutôt que pour les 
programmes. Dans ce cas, 
les structures de bits 
définissent la façon dont les 
caractères apparaîtront à 
l'écran. Certains ordinateurs 
permettent de copier tout ou 
partie des données en RAM, 
ce qui laisse la possibilité 
de définir de nouveaux 
caractères. 


Programme noyau 

Le programme noyau est 

le cœur du système 
d'exploitation. C'est 

le programme 
systématiquement exécuté 
lors du démarrage de 
l'ordinateur. Il comptabilise 
la RAM disponible et vérifie 
si la cartouche programme 
est présente. Le programme 
noyau gère également les 
formes les plus simples 
d’entrée/sortie. 
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Les logiciels de simulation 
permettent de faire des 
expériences scientifiques sans 
appareils, sans spécimens et sans 
matériaux, chez soi ou à l’école. 


Les programmes de simulation, tels les jeux 
qui vous permettent de prendre les comman- 
des d’une formule 1 ou d’un avion, sont 
conçus pour vous placer dans une situation 
aussi proche de la réalité que possible. Mais 
il existe également toute une gamme de logi- 
ciels de simulation qui cherchent à éduquer 
plus qu’à distraire. Ces programmes sont 
très utiles à l’école, surtout dans les matières 
où les travaux pratiques seraient trop diffi- 
ciles à organiser. 

Des programmes de simulation sont aussi 
à la base des jeux éducatifs que l’on peut pra- 
tiquer chez soi. Par exemple, un programme 
qui s’appelle Promenade en voiture apprend 
aux enfants à se servir de leurs connaissances 
en arithmétique et de leurs capacités de rai- 
sonnement pour « conduire » une voiture sur 
un itinéraire entre plusieurs villes. De tels 
programmes représentent le type de logiciel 
éducatif le plus stimulant qui se fait actuelle- 
ment; malheureusement, ils n’existent que 
pour quelques machines. 


Distance nf obrect From 

23 cn HD. 

glasses l6LASSES Hi 
ù LIGHT  OBJECT. 
Normal sight. HISIGHT 


Press the first letter of » comnmand_ 


Ce programme explique le fonctionnement de 
l’œil, en montrant que, pour qu’on voie clair, 
tous les éléments de l’organe doivent être bien 
réglés. Il simule le passage d’un rayon de 
lumière à partir d’un objet jusqu’à la rétine (le 
fond de l’œil, où se forment les images). Le 
joueur tient le rôle du cerveau et agit sur des 
paramètres tels que l’éloignement de l’objet, 


l’ouverture de la pupille et la longueur focale de 
la lentille, afin d’obtenir une image nette sur la 
rétine. Sur l’écran l’œil est représenté en éclaté, 
les éléments fonctionnels étant repérés par des 
étiquettes. Au moyen de la commande LUMIÈRE, 
la trajectoire d’un rayon de lumière peut être 
matérialisée, de l’objet jusqu’à l’œil. Si toutes 
les variables sont bien réglées, on voit apparafî- 
tre le message « AU POINT ». Sinon, l’ordinateur 
signale (« BROUILLÉ ». 

Une fois maîtrisé le fonctionnement normal 
de l’œil, on peut passer à la simulation de 
défauts, comme la myopie, par exemple. Il 
devient impossible de faire la mise au point sur 
un objet éloigné : il faut ajouter une lentille sup- 
plémentaire. Si le joueur choisit correctement 
cette lentille, la vision normale est retrouvée : il 
a réussi sa première prescription ophtalmologi- 
que. Conçu d’abord pour des cours de biologie 
et de physique, ce programme sert souvent 
d'initiation à l’informatique pour les jeunes. 
Ce sont ses qualités de clarté, de simplicité 
d’emploi et de fiabilité qui expliquent ce choix. 
Le programme est conçu pour le BBC Micro. 


La montgolfière 


Distance: 1km 


La montgolfière est un programme éducatif 
pour les enfants âgés de huit à douze ans, pro- 
duit pour le Spectrum. Le joueur doit piloter 
une montgolfière. Sur l’écran il voit le terrain en 
coupe, avec l’image du ballon qui, au départ, 
repose sur le sol. Des renseignements utiles sont 
donnés par quatre cadrans qui s’affichent sur 
l’écran : vitesse de montée ou de descente, tem- 
pérature de l’air, altitude, carburant. On dis- 
pose simplement de deux commandes : telle du 
brûleur à gaz qui chauffe l’air pour faire monter 
le ballon et celle de la soupape qui laisse échap- 
per l’air pour entraîner le ballon vers le bas. 
Une « leçon de vol » très simple initie le 
joueur à l’emploi des commandes et des jauges 
pour décoller, voler et atterrir. Une fois maîtri- 
sées ces techniques de base, vous êtes prêt à par- 
tir pour votre « mission ». Pour cela, il faut 


atterrir à une série de points sélectionnés (mar- 
qués d’un X) pour recevoir chaque fois des ins- 
tructions. Par exemple, il s’agira d’aider un ber- 
ger à retrouver des moutons égarés, en allant 
jusqu’au champ (marqué sur l’écran) pour les 
chercher. Si le ballon manque de carburant, il 
faut atterrir pour charger de nouveaux cylindres 
de gaz. 

Après quelques petits incidents au départ, 
vous apprenez vite à contrôler le ballon avec 
précision, au moyen de petits coups de brûleur. 
Il faut aussi surveiller les cadrans pour savoir à 
l'avance s’il faut agir sur la soupape ou le brû- 
leur. On apprend surtout à contrôler un système 
qui ne réagit qu’avec un certain délai. 

Ce programme très fidèle à la réalité amuse 
bien son public, et c’est probablement un des 
rares sujets de « jeux » qui intéressent autant les 
filles que les garçons. Peut-être parce que ce 
programme conjugue réalisme et poésie! 


Promenade en voiture 


S00KE0 Fuel Consumption 
F1 


Maximum 
speed 
Fuel tank 
capacity 
Hire cost 


per day $ 


Conçu pour le Spectrum, ce programme éduca- 
tif met le joueur dans la situation de l’exploitant 
d’une petite entreprise de messageries. Il lui faut 
prendre des décisions concernant le choix des 
contrats à accepter, la vitesse de croisière à 
adopter, le type de véhicule à utiliser. Le 
joueur est amené à faire des calculs sur l’argent, 
les distances, le temps et même la consomma- 
tion d’essence. Une carte du pays est visualisée, 
avec quinze villes et les principales autoroutes. 
Le compteur de vitesse, le totalisateur kilomé- 
trique, la jauge d’essence et une montre figurent 
également sur l’écran. 

La première tâche du joueur est de fixer sa 
ville de départ, puis de choisir, parmi une dou- 
zaine de possibilités offertes, le contrat qui lui 
semble réalisable et rentable. Par exemple, il 
peut lui être demandé de chercher un paquet de 
diamants à Orléans à midi et de le livrer à Calais 
avant 18 heures le même jour. Pour cela, il faut 
louer une voiture, la conduire jusqu’à Orléans, 
aller chercher le paquet, et rouler jusqu’à 
Calais. S’il réussit, il gagne 4 000 F, plus une 
prime de 100 F pour une livraison en avance sur 
l'horaire. Il peut ensuite choisir un autre 
contrat. Il faut dépenser de l’argent pour les 


nuits d’hôtel, les réparations, l’essence et les 
amendes pour excès de vitesse. Si jamais il ne 
remplit pas correctement le contrat, le forfait 
est de 1 000 F. S’il accepte un chargement 
lourd, il lui faut échanger la voiture contre une 
camionnette qui coûte cher, consomme davan- 
tage et roule moins vite. 

Ce jeu met en pratique des connaissances en 
géographie, mais aide surtout à développer la 
capacité de réflexion logique et de prise de déci- 
sion. Il enseigne même des rudiments d’écono- 
mie car en pesant le pour et le contre d’un 
contrat, le joueur se livre, en fait, à une analyse 
de rentabilité. 


Survie 


Vous êtes-vous jamais posé la question de 
savoir comment vit un lion (ou une souris)? 
Alors, Survie est un jeu pour vous. Il vous per- 
met de jouer le rôle d’un animal (épervier, 
rouge-gorge, lion, souris, mouche, papillon), 
d’être confronté aux problèmes qu’il rencontre 
dans sa vie de tous les jours, et de comprendre 
les décisions qu’il doit prendre pour survivre. 
Le monde est représenté par une grille sur 
l’écran. Vous vous déplacez d’une case à l’autre 
en tapant les coordonnées sur le clavier. Vos 
soucis principaux sont de rechercher la nourri- 
ture (les cases marquées d’un 0), et d’éviter les 
prédateurs (les cases marquées d’un X). A 
mesure que vous vous approchez d’une case 
marquée, un agrandissement à droite de l’écran 
vous indique la nature exacte de l’ennemi ou de 
la nourriture que vous allez rencontrer. Egale- 
ment visibles, deux jauges vous montrent vos 
réserves en énergie et en eau. Si votre niveau 
d’énergie baisse trop, il vous faut chercher de la 
nourriture sans tarder; si vous manquez d’eau, 
il faut vous approcher d’une case bleue (mais 
sans vous y poser, Car Vous seriez « noyé »). 
Certains animaux ont une vie plus difficile 
que d’autres : le papillon doit chercher sa nour- 
riture sur des fleurs qui sont parfois difficiles à 
trouver. L’épervier se nourrit d’escargots, de 
mouches et de souris, mais doit craindre 
l’homme. A travers Survie, vous apprendrez la 
place de chaque espèce dans la chaîne alimen- 
taire, et vous évaluerez les problèmes qui se 
posent aux animaux dans leur milieu naturel. 


lan McKinnell 
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ET | 
Le bon choix 


Trouver la meilleure solution d’un problème est parfois chose facile, 
mais requiert souvent un haut niveau mathématique. Pour l’ordinateur 


L’ajustement parfait 
L'arrangement de patrons 
sur une feuille de métal ou 
une pièce de tissu pour 
minimiser les chutes est un 
bon exemple d'optimisation 
par ordinateur. Dans un 
cas, il s’agit de découper 
de la tôle, dans l’autre de 
façonner des vêtements. 
L'ordinateur affiche sur 
l'écran la disposition qu'il 
propose, et un opérateur 
expérimenté peut ensuite 
effectuer des ajustements 
mineurs à l'aide d'un 
crayon lumineux. 

(CI. Kevin Jones/ 

Burtons Tailoring.) 
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c’est un jeu d’enfant. 


Dans toute décision que nous prenons, il existe 
inévitablement un compromis — entre prix et 
qualité, ou temps et argent, par exemple. Il est 
peu probable d’obtenir dans l’absolu une effica- 
cité maximale pour un coût minimal. L’« opti- 
mum » se situera quelque part entre les deux. 
Si, par exemple, nous avons le choix entre 
deux marques de poudre de lavage, le raisonne- 
ment sous-jacent à la décision sera à peu près le 
suivant : « Si j’achète cette poudre de lavage, 
elle me coûtera 7,50 F les 500 g, mais si je 
prends celle-là, j’en aurai pour 13,80 F le kg. 
Mais que se passera-t-il si, avec la poudre la 
moins chère, je dois en utiliser 20 % de plus 
pour obtenir le même résultat? Quelle marque 
sera alors la plus avantageuse? » La réponse est 
facile à prévoir, même avant d’entamer le calcul 
qui revient à des différences de pourcentage. 
Le concept de « pondération » d’un calcul 
par une valeur constante est bien connu. Cette 
méthode marche bien lorsque les écarts entre 
éléments similaires (le prix, par exemple, ou 
bien le poids) sont eux-mêmes constants. Mais 
quand ces écarts eux-mêmes varient, alors les 
mathématiques se compliquent, et nous devons 
avoir recours à une forme de calcul (où il faut 
résoudre un système d’équations comportant les 


mêmes termes) pour parvenir à la réponse 


exacte. Si le nombre de termes est petit, nous 


pouvons les regrouper dans un tableau, afin de 
les manipuler. On peut aussi essayer de deviner 
une réponse, puis la modifier successivement 
jusqu’à ce qu’elle vérifie les conditions. Natu- 
rellement, meilleure sera l’estimation moins le 
temps de calcul durera. 

Ces techniques d’optimisation sont essentiel- 
les dans le commerce et l’industrie, et sont uni- 
versellement appliquées, surtout dans la fabri- 
cation et la construction. La programmation 
linéaire, l'analyse du chemin critique et la 
méthode PERT (technique de recherche d’éva- 
luation de programme) sont des noms donnés 
à des méthodes d’optimisation. Ces méthodes 
précédèrent d’une trentaine d’années l’ère de 
l’informatique. Elles exigeaient d’énormes 
efforts pour obtenir une réponse correcte dans 
un délai acceptable. De telles applications 
conviennent tout à fait aux ordinateurs domes- 
tiques, mais il ne faut pas oublier que les opéra- 
tions sur les matrices (tableaux à deux dimen- 
sions) exigent un espace mémoire important, et 
que le calcul est assez complexe. Heureusement, 
il existe,de nombreux logiciels pour les petits 
systèmes informatiques, de sorte que cette tech- 
nique est aisément utilisable. 

Un domaine commercial qui a considérable- 
ment bénéficié de l’optimisation est celui de la 
confection. Les vêtements se font normalement 


A\ 
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PATATES 


200 g SARDINE 


400 g VIANDE 


1/2 LITRE 
DE LAIT 


MINIMUM NÉCESSAIRE 
PAR SEMAINE 


dans des tailles standard. Le problème du fabri- 
cant consiste à minimiser les chutes de tissu, 
tout en restant attentif à des facteurs tels que la 
direction des fils de l’étoffe. 

Chez l’un des tailleurs les plus modernes 
d’Europe, la disposition des pièces du patron 
sur une longueur donnée de tissu pour la pro- 
duction de prêt-à-porter est effectuée grâce à 
des techniques d’optimisation, et le résultat pro- 
posé est montré sur une console de visualisa- 
tion. À ce stade, utilisant des méthodes de pro- 
grammation orientées par l’objet, l’opérateur 
doit exercer son jugement et son expérience afin 
de tenter d’améliorer le calcul sur ordinateur. 
L'opérateur réalise, en moyenne, une améliora- 
tion une fois sur cinq. 

Les exigences de chaque travail, ou de chaque 
vêtement, diffèrent. C’est un excellent exemple 
de l’usage intelligent d’une optimisation sur 
ordinateur combinée avec l’expérience de l’opé- 
rateur. Dans l’industrie, on utilise des méthodes 
à plus grande échelle pour couper de façon répé- 
titive des objets identiques dans de grandes piè- 
ces de métal; tout le processus d’optimisation 
peut alors suivre son cours. Etant donné que les 
opérations de coupe et d’impression constituent 
une partie d’une chaîne de production, elles 
sont répétées des milliers de fois. Dans ce cas, le 
coût du processus d’optimisation divisé par le 
nombre de pièces fabriquées est largement cou- 
vert par les économies réalisées sur les chutes. 

Comme son nom l'indique, l’analyse du che- 
min critique sert à déterminer la partie du tra- 
vail ayant la plus grande probabilité d’entraver 
le reste, s’il n’est rien prévu de particulier. C’est 
une méthode fondée sur le temps : la période 
exigée pour l’exécution d’une tâche devenant 
élément sur le diagramme d’analyse de chemin 
critique. Elle est couramment utilisée pendant la 


Optimisation d’un régime 
Dans cet exemple, 

il s’agit de trouver la 
combinaison optimale 
de quatre aliments, qui 
satisfasse un besoin 
diététique spécifique 
minimal et pour un coût 
le plus bas possible. 
Pour cela, nous devons 
entrer dans l'ordinateur 
la composition (en rose) 
et les prix unitaires 

(en bleu) de chaque 
aliment, ainsi que les 
besoins minimaux pour 
chaque composant 
alimentaire par semaine 
(en jaune). Dans cet 
exemple, les besoins 
ont été satisfaits rien 
qu'avec les pommes de 
terre et le lait, pour un 
prix minimal de 48 F par 
semaine. 

(N.B. — ce régime n'est 
pas recommandé.) 

(CI. Kevin Jones.) 


phase de planification de projets de construc- 
tion, de sorte que les entrepreneurs peuvent 
assigner des hommes et des matériaux aux diffé- 
rentes phases du projet dans le bon ordre — la 
plomberie avant les parquets, les peintures 
après les plâtres. Là encore, des logiciels sont 
disponibles pour une large variété de micro- 
ordinateurs. 

Tandis que les mathématiques des processus 
d’optimisation peuvent être assez découragean- 
tes pour les non-initiés, on ne peut nier le succès 
et l’efficacité de la technique elle-même. C’est 
l’une des rares tâches numériques accomplies 
communément sur des mini-ordinateurs. Elle 
constitue une composante importante des sys- 
tèmes d’intelligence artificielle qui reproduisent 
le raisonnement commun. 


Cauchemar d’autoroutes 
Le tracé des autoroutes, 
en agglomération comme 
à la campagne, dépend 
beaucoup des techniques 
d'optimisation. L'architecte 
sera surtout concerné par 
les dénivellations et les 
courbes. Mais le fermier, 
qui a été dépossédé de sa 
terre, n'aura pas les mêmes 
critères. Lorsqu'une 
nouvelle route est prévue, 
on rassemble une grande 
quantité de données qui 
servent à établir un modèle 
d'ensemble de la situation. 
Ce modèle est ensuite 
utilisé pour des objectifs 
variés, qui vont de la 
représentation graphique 
jusqu'à l'optimisation 

du tracé. 

(CI. Ministère des 
Transports.) 
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Electron de Acorn 


Au cours des deux années qui 
séparent chez Acorn le BBC Model B 
de l’Electron, la technologie micro- 
informatique s’est développée 

de manière spectaculaire. 


Acorn Electron est un micro d’aspect agréable 
dont l’usage confirme l’impression initiale de 
robustesse et de fiabilité. Il s’agit d’un modèle 
issu du BBC Micro, mais moins performant. En 
revanche, son utilisation se révèle être plus sou- 
ple. La plupart des caractéristiques du BBC 
Micro ont été reprises dans l’Electron. Ainsi la 
commande SOUND est utilisée conjointement avec 
ENVELOPPE pour générer le timbre de divers instru- 
ments, comme sur le BBC Micro. 

Tous les modes graphiques du BBC existent 
sur l’Electron, à l’exception de Teletext [MODE 7), 
généré par un composant propre au BBC. 
L'affichage de type Teletext sur l’Electron 
devra se faire en redéfinissant la plupart des 
caractères et en imitant le mode Teletext par 
l’intermédiaire du MODE 6 (limité à deux cou- 
leurs). Cette lacune est un sévère handicap, car 
Teletext sur BBC Micro est un mode d’affi- 
chage puissant, économe de place en mémoire. 

Les entrées-sorties sont également moins per- 
formantes. La sortie image se fait via le canal 36 
de la télévision ainsi que par l’intermédiaire du 
support vidéo polyvalent et du support RVB 
(rouge, vert, bleu), vers des moniteurs mono- 
chromes ou couleur. En dehors du port cassette, 
il n’existe pas sur l’Electron d’interface directe- 
ment utilisable. 

Une connexion à l’arrière de la machine per- 
met d’envisager une extension. Malheureuse- 
ment, cette dernière est mal située — en saillie 
sous un renfoncement — et mal protégée. En 


Un duo dynamique 

Les créateurs de l'Electron sont Chris Curry (à gauche) 
et Hermann Hauser (à droite). Ils sont également à 
l'origine du BBC Micro. Curry était ingénieur du 
développement chez Clive Sinclair lorsque ce dernier 
engagea Hauser. (CI. Judy Goldhill.) 
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Quartz principal 


Quartz pilote du signal TV 
Il assure à l’image de 
l'Electron une parfaite 
stabilité du fait de sa 
spécificité. 


Modulateur TV et prise de 
sortie 


Prise vidéo polyvalente 


Prise RVB 


Prise cassette 


Relais moteur cassette 
L'ordinateur ne pouvant 
supporter le voltage trop 
élevé du lecteur de 
cassettes, ce minuscule 
relais en assure l'interface. 


Haut-parleur 


outre, le manuel ne dit rien de la finalité de cette 
extension ou du signal transmis. Mais il doit 
s’agir d’un boîtier intermédiaire puisqu'il y a un 
dispositif de verrouillage mécanique. 

Le BASIC résident est le fameux langage BBC, 
sensiblement étendu et dont de nombreuses 
caractéristiques rendent la machine agréable à 
utiliser. La routine OSCLI se révèle particulière- 
ment utile puisqu’elle permet à un programme 
BASIC d’envoyer des commandes directement au 
système d’exploitation, libérant le program- 
meur confirmé de certaines contraintes du 
BASIC. Le programme assembleur (une des 


Connection clavier 

Le nombre de broches (22) 
indique que la sortie clavier 
n'est pas décodée en code 
ASCII. Si c'était le cas, 

il y aurait tout au plus 

10 broches (8 pour les 
données, 1 pour le courant 
5 volts, et 1 pour le sol). 

Il s'agit probablement d'une 
fonction traitée par l'unité 
arithmétique et logique 
(ULA). 


Clavier 

Le clavier est parmi les 
meilleurs possibles, de type 
machine à écrire, et 
d'excellente qualité. Il se 
révèle très semblable à 
celui du BBC. Il n'existe 
pas de touches de 
fonctions programmables, 
mais la touche "Caps Lock 
Key" offre des ressources 
équivalentes. En effet la 
frappe de cette touche, 
simultanément à celle 
d'une touche numérique 
revient à solliciter une 
touche fonction. 


Connecteur d'extension 

Il n'est pas fourni de détails 
. Sur la valeur des broches 
ou sur la synchronisation 
du signal; cependant, 

la connection autorisera 
certainement la plupart des 
fonctions du système bus, 
et des lignes transistor- 
transistor line (TTL) 

et alimentation électrique. 


> 


Unité centrale 

Le microprocesseur est un 
6502A standard régulé par 
une horloge à 1,79 MHz. 
C'est le lieu des décisions, 
ce que ne peut faire l'unité 
arithmétique et logique. 


Réseau de portes 
programmables 

Il s’agit de la plus grande 
ULA jamais construite. En 
dehors de l'ULA, l'unité 
centrale 6502A, la RAM et 
la ROM, il n'y a que neuf 
composants sur la carte 
fond de panier, tous en 
logique TTL, chacun ne 
fournissant que quelques 
portes logiques. 


RAM 
Les octets sont chargés de 
la RAM dans l'UC en deux 
temps. Les 4 bits de poids 
faible sont d'abord 
accessibles (1 bit de 
chaque puce) puis les 

4 autres de poids fort. 

Dans la plupart des 
machines, les 8 bits sont 
stockés dans la même puce. 


Circuits de régulation 
d'alimentation 
L'alimentation de Acorn 
Electron est originale : 

1 volt en alternatif. La 
stabilité du courant en est 
accrue, mais les circuits de 
régulation de l'alimentation 
pour l'ordinateur s'en 
trouvent compliqués. 


caractéristiques uniques du BASIC BBC) a égale- 
ment été étendu par rapport au BBC Micro. Il 
comporte des mots clés supplémentaires pour 
définir le stockage des variables et pour l’affi- 
chage des chaînes, supprimant la corvée de leur 
écriture en langage assembleur. 

Le micro-ordinateur Acorn Electron peut être 
considéré comme au-dessus de la moyenne pour 
ses performances. L’image transmise est stable 
et de bonne définition, les couleurs sont bien 
distinctes. Avec l’adjonction d’extensions 
appropriées, telles que les lecteurs de disquettes, 
il pourra prétendre à une grande diffusion 
auprès du public. 


Zone libre sur 28 broches 
Cet emplacement, disposé 
pour recevoir un composant 
et ayant à proximité un lien 
libre, semble suggérer 
l’adjonction possible 

soit d'un bloc de mémoire 
morte supplémentaire 

et commutable, soit 

d’un autre composant. 
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1,79 MHz. 


ROM 64 K. 
RAM 32 K (sans compter les 
extensions possibles). 


8 couleurs avec les couleurs 


127 caractères prédéfinis, 
et 255 caractères à définir 
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(BUS sans documentation). 


BASIC BBC avec assembleur. 


Utilise les langages 
AcornSoft, tels que le FORTH, 
pourvu qu'ils figurent en 


et PASCAL sont incompatibles 
avec une machine sans 
extension. 


Manuel d'installation et 
manuel BASIC, câble TV, 
transformateur, cassette 
d'explications. 


56 touches style machine à 
écrire, une seule clé d'accès 
au BASIC. 

10 fonctions paramétrables 
par l'utilisateur. 


Simplement excellente. 
L'ensemble des éléments 
d'information se révèle très 
utile aussi bien pour le 
débutant que pour le 


{assembleur incorporé). 
Les fonctions du système 
d'exploitation sont bien 


devraient s'en trouver 
facilitées. 


371 


Jet d'encre 


L’impression couleur est devenue 
possible à un prix raisonnable 
avec l’apparition d’une imprimante 
à jet d’encre de couleur sur papier 
point par point. 


1 ER APPOR GE EN EE ER ce AMAR VU EL ET SRESREPE EEE 


Les divers types d’imprimantes disponibles 
pour un ordinateur individuel sont d’une qua- 
lité d’impression très inégale. Les imprimantes à 
impact de caractère entier donnent les meilleurs 
résultats (les imprimantes dites à « marguerite » 
en sont un bon exemple). Les résultats les plus 
médiocres sont obtenus avec des imprimantes 
thermiques et électrostatiques. Cependant 
l’imprimante à matrice de points, bien que de 
qualité moyenne et assez bruyante, est la plus 
répandue. 

Avec l’apparition de systèmes nouveaux tels 
que l’imprimante-traceur GP 115 de Tandy, 
les limites des imprimantes à matrice de points 
sont devenues plus évidentes. L’imprimante- 
traceur utilise de minuscules aiguilles pour des- 
siner des caractères complets ou pour tracer des 
graphiques, quelquefois en quatre couleurs. 
Mais le système le plus intéressant est celui de 
l’imprimante à jets d’encre : de microscopiques 
jets d’encre sont ordonnés pour former un gra- 
phisme particulier. 

Après l’industrie et le secteur tertiaire (où 
elles cohabitent avec les imprimantes à laser 
également très évoluées), ces imprimantes à 
encre abordent la micro-informatique. L’encre 
est transmise depuis un réservoir jusqu’à 
l'extrémité d’un gicleur extrêmement fin. De 
minuscules particules d’encre sont alors électri- 
sées à haut voltage avant d’être éjectées. La 
valve est de type piézo-électrique. Elle permet 
de donner une forme à la projection d’encre par 
l’intermédiaire de vibrations à haute fréquence. 

La giclée d’encre est prise dans un champ 
électrique et se trouve attirée par une charge 
électrique inverse à la sienne qui la conduit sur 
le papier. Comment cette rencontre est-elle pos- 


sible? Grâce à la présence d’une plaque métal- 


lique (sur laquelle est tendue la feuille de papier) 
dont la charge électrique est du signe opposé à 
celui des gouttelettes. Le principe est simple 
mais surprenant pour une imprimante. La fiabi- 
lité est correcte. Dans le pire des cas, l’ajustage 
se bouche ou les gouttes d’encre deviennent trop 
grosses. 

Une imprimante à jet d’encre fonctionne 
selon le même principe qu’une imprimante à 
matrice de points à un seul marteau. La chaîne 
des caractères ASCII parvenant à l’imprimante 
est stockée dans une mémoire tampon jusqu’à 
ce qu’elle se remplisse ou jusqu’au prochain 
retour du chariot. L’imprimante examine alors 
un par un les caractères et recherche leurs équi- 
valents en ROM. Généralement, chaque carac- 
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. Li . L4 
Missiles guidés 
Les premières 
imprimantes à jet d'encre 
étaient très compliquées 
et onéreuses. Un flux 
constant d'encre chargée 
électriquement se 
déplaçait verticalement, 
guidé par deux 
électrodes. La tête 
d'impression balayait la 
feuille. En l'absence de 
caractère à imprimer, 
l'encre revenait dans un 
entonnoir avant d'être 
renvoyée dans le réservoir 
principal. 


P4 
ÉLECTRODES st 
NNOIR 


RÉSERVOIR 


Pompe d’amorçage 
Cette pompe manuelle sert 
à injecter l'encre de force 

dans les gicleurs, pour les 
déboucher ou les amorcer. 


Circuit imprimé 
L'imprimante possède 
son propre 
microprocesseur 6809, 
ROM et RAM. Les données 
reçues sont stockées dans 
une mémoire tampon (une 
seule ligne de points étant 
imprimée par passage). 


Clapet de sécurité 
La tête d'impression étant 
très fragile, un clapet 
l’obstrue lorsqu'elle n'est 
pas en fonctionnement. 

Il convient de respecter 
les procédures de mise 
en route sous peine 
d'endommager la machine. 


EE 
Impression par brûlure 

Cousine de l'imprimante à projection d'encre liquide, l'impri- 
mante à « encre sèche » est un système fondé sur l'érosion du 
papier par brûlure. Une étincelle est produite par un voltage 
très élevé. Elle fait un trou dans du papier d'argent (par exem- 
ple avec l'imprimante ZX). Le système Olivetti utilise l'étin- 
celle pour déplacer des particules de carbone depuis la 
pointe d’un bâtonnet jusqu'au papier. Ce système correspond 
à celui de l'imprimante Acorn pour le BBC Micro. Les avan- 
tages de ces imprimantes par rapport aux imprimantes matri- 
cielles classiques sont. le silence, la légèreté de la tête 
d'impression (plus de moteurs surpuissants) et l'absence de 
contraintes concernant le papier. Les véritables inconvé- 
nients sont la lenteur de l'impression (une seule ligne de 
points par passage) et le fait que l'encre a trop tendance à dif- 
fuser, à baver. 


tère est constitué d’un certain nombre de points 
disposés sur une grille de 8 X 8 que l’impri- 
mante reproduit sur le papier. Pour être nette, 
une ligne de caractères demande huit passages 
de la tête d’impression, mais la vitesse est aug- 
mentée en permettant à l’imprimante de fonc- 
tionner dans les deux sens. Au cours d’une opé- 
ration d’impression a lieu le chargement du lot 
de caractères suivants, de sorte que dès 


l’impression du premier lot achevée commence 
celle du suivant. 


La seule différence entre 


l'imprimante à jet d’encre et l’imprimante à 
matrice de caractères est que la première pro- 
jette des gouttelettes d’encre chargées électri- 
quement, alors que la seconde percute la page à 
travers un ruban d’encre. 

Dans leur version commerciale, les impri- 
mantes à jet d’encre peuvent imprimer une page 
en quelques secondes seulement. La qualité 
d’impression est bien meilleure si le papier ne 
« boit » pas. Pour des applications de grand 
volume, de niveau professionnel, c’est l’idéal. 


Électrode métallique 
Derrière le papier, une 


plaque métallique chargée 
d'une tension opposée à 


celle des particules d'encre. 
Cette différence provoque 
l’'attirance des gouttelettes 


Tête d'impression 

Cette tête comporte ici 
quatre gicleurs et des 
cellules piézo-électriques 
qui sont à l'origine des 

| variations de pression 
Réservoirs d’encre créant l'émission d'encre. 
Une encre spéciale doit être 

utilisée pour éviter 

l'engorgement. L'encre 

noire, utilisée en grande 

quantité, est située dans 

une cartouche séparée des 

encres rouge, bleue 

et jaune. 


sur le papier. 


Moteurs d'entraînement 

Le glissement transversal 
de la tête d'impression est 
assuré par un moteur 
conventionnel. L'avance du 
papier est assurée par un 
moteur pas à pas, comme 
pour une imprimante à 
matrice de points. 


Liaisons flexibles 

La plupart des imprimantes 
possèdent des câbles- 
nappes flexibles de liaison 
entre la carte et la tête 
d'impression. 

La vitesse du dispositif 
d'impression rend 
l'alimentation en encre 
délicate (quatre encres de 
couleurs différentes). 


Pour des vitesses d'impression encore plus éle- 
vées, l’imprimante à laser conviendra mieux 
(elle fonctionne suivant le principe d’une photo- 
copieuse). 

Avec le Tandy CGP220, l’imprimante à jet 
d’encre autorise l’impression couleur pour un 
ordinateur domestique. Elle dispose de réser- 
voirs et de gicleurs séparés pour les encres 
magenta (rouge-bleu), cyan (bleu-vert) et jaune. 
Bien que différant des couleurs habituelles obte- 
nues sur un écran télé, ces couleurs sont les 
équivalents du rouge, du vert et du bleu pour les 
peintres et elles peuvent être mélangées de 
manière très souple. Les résultats comparés à 
ceux obtenus avec une imprimante à matrice de 
points utilisant des rubans de diverses couleur 
sont nettement meilleurs. L’inconvénient de ce 
système réside non pas tant dans son prix, mais 
dans le fait que le papier doit être absorbant, au 
risque de « baver » et d’obtenir une image 
floue. 
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Synthèse du son : 
le Dragon 32 à l’épreuve. 


Le Dragon 32 est muni d’un seul oscillateur à 
onde carrée pour programmer le son. Mais les 
instructions sonores remarquablement simples 
du BASIC Extended Color de Microsoft per- 
mettent de construire une chaîne musicale qui 
joue un petit air à l’aide d’une seule com- 
mande, même s’il n’existe pas de générateur de 
bruit. 

L’instruction SOUND ne sert que pour les effets 
sonores et le format est le suivant : 


SOUND H,D 


où H = hauteur (1 à 255) et D = durée (1 à 255). 
La hauteur est très imprécise et comporte peu de 
relation avec la gamme musicale, quoique le do 
majeur puisse être approximativement remplacé 
par la valeur 89 et le /a de référence à 440 Hz par 
159. La durée est également inexacte, mais 16 
est proche de 1 s, 32 de 2 5, etc. 

Le programme suivant montre comment on 
peut utiliser SOUND pour obtenir un effet spécial; 
voici, avec un peu d’imagination, le décollage 
d’un ovni : 

10 FOR H = 10 TO 170 STEP 10 
20 FOR D = 16 TO 1 STEP - 1 
30 SOUND H,D 

40 NEXT D 

50 NEXT H 


coloré 


Suite de la première présentation 
des possibilités graphiques du 
BBC Modèle B. 


Le BASIC BBC ne fournit pas toutes les instruc- 
tions haute résolution que l’on trouve sur cer- 
tains micro-ordinateurs. Par exemple, les ins- 
tructions CIRCLE ou PAINT n’existent pas. Il est 
néanmoins possible de les simuler à l’aide de 
quelques lignes de BASIC BBC. 

Les instructions suivantes permettent le 
contrôle de l’écran graphique : 


MOVE x, y 


Cette instruction déplace le curseur graphique 
jusqu’au point de coordonnées (x, y), mais sans 
tracer de ligne. 


PLAY fixe exactement la hauteur, la durée et le 
volume d’une note. Elle peut aussi spécifier 
qu’une série de notes soit jouée avec des silences 
et un tempo variable. Cela permet de construire 
des mélodies comprenant des notes et des silen- 
ces de longueurs différentes, à l’aide de la seule 
instruction : 


PLAY « TO; V:LN;P » 


où T = tempo (T1 à T255); 0 = octave (01 à 
05); V = volume (VO à V15); L = longueur de la 
note (L1 à L255); N = valeur de la note (1 à 12 
ou nom de la note); et P — pause avant la note 
suivante (P1 à P255). 

Il n’est pas indispensable d’utiliser les points- 
virgules entre les paramètres, mais la clarté y 
gagne. Cet exemple n’est qu’une représentation 
arbitraire, puisque les paramètres peuvent être 
placés dans n’importe quel ordre. T, 0, Vet L gar- 
dent leurs valeurs jusqu’à une nouvelle instruc- 
tion. En fait, T, 0, V, Let P prennent les valeurs 
respectives de T2, 02, VI, L4 et PO, à moins d’une 
autre spécification, de sorte qu’il n’est pas tou- 
jours nécessaire de les inclure dans l'instruction 
PLAY. 

Là où le temps intervient, comme dans Let P, 
les valeurs spécifiées peuvent être considérées 
comme des « notes » et des fractions de « note » : 
L1 ou PI est une note entière, L2 ou P? une demi- 
note, etc. Leur rythme est choisi à l’aide du 
paramètre « T », où T1 est lent (une note dure 
longtemps) et T255 est très rapide (une note est 
très brève). En outre, les longueurs des notes 


DRAW x, y 


DRAW (= dessiner) trace une ligne à partir de la 
position du curseur graphique jusqu’au point de 
l’écran de coordonnées (x, y). 


PLOT K, x, y 


PLOT est une instruction à usages multiples; sa 
fonction est gouvernée par la valeur donnée à la 
variable K : 


Valeur de K Fonction 

0 déplace par rapport au dernier 
point ; 

1 trace une ligne à partir de l’ori- 
gine dans la couleur de l’avant- 
plan; 

2 trace une ligne à partir de l’ori- 
gine dans la couleur complé- 
mentaire ; 

3 trace une ligne à partir de l’ori- 
gine dans la couleur du fond; 

4 même chose que MOVE; 

5 même chose que DRAW; 

6 même chose que DRAW mais en 
couleur complémentaire ; 

7 même chose que DRAW mais 


dans la couleur du fond. 


peuvent être définies avec plus de souplesse en 
ajoutant des points tels que LI. ou L5., chaque 
point augmentant la longueur de la note de la 
moitié de sa valeur normale. Ainsi 


A 


notes et 


1 + 1 = 3 de note. 
n] 10 10 

Il n’existe pas, dans l’absolu, de moyen de 
représenter la relation entre note et tempo. Les 
valeurs peuvent varier pour chaque air et seront 
choisies à la suite d’essais. Cela peut prendre du 
temps, mais l’instruction y gagne en souplesse. 

Le paramètre 0 spécifie l’octave dans laquelle 
la prochaine note doit être jouée. 01 commence 
par le do à 131 Hz et 05 termine par le si à 
2 039 Hz. Le do médian commence l’octave 02. 
A l’intérieur d’une octave, les notes peuvent 
être spécifiées de deux manières. La première 
utilise un nombre qui correspond à une note 
musicale de la façon suivante : 


l 2 3 4 S 6 


L5. = 


do dot ré ré# mi fa 
7 8 9 10 11 12 
fat sol sol # la la # si 


Il est ainsi possible de spécifier une note comme 
une variable à l’intérieur d’une octave donnée. 
La seconde désigne directement la note par son 
nom pour rendre l’instruction plus compréhen- 
sible dans un listage. 

Un exemple illustrera mieux ces explications. 
L’instruction suivante joue fa (6) de l’octave 02, 
pendant la moitié de durée d’une note {L?) au 
volume {V15). Puis il y a un silence durant un 


Les nombres supérieurs répètent ces huit fonc- 
tions, mais avec des effets supplémentaires tels 
que des pointillés au lieu de traits continus. Les 
valeurs de K comprises entre 80 et 87 accomplis- 
sent une fonction particulièrement utile. PLOT 
80,x,y joint le point (x) aux deux derniers points 
tracés pour former un triangle. L’intérieur du 
triangle se remplit de la couleur d’avant-plan. 
C’est là la seule manière simple de « peindre » 
des formes graphiques. 

VDU x est l’équivalent de l’instruction BASIC 
PRINT CHR$ x. Nous avons vu, dans l’introduc- 
tion aux graphiques sur le Micro BBC, que VDU 
peut être suivi d’une série de nombres. VDU 
V,W,X,yZ est équivalent à : 


PRINT CHR$IV);CHR$lw] ;CHRSIxI;CHR$Iy);CHR${a) 


Les instructions VDU permettent à l'utilisateur 
d’accéder à la partie du système d’exploitation 
qui contrôle l’affichage. Quoique l'instruction 
VOU puisse être utilisée dans les programmes en 
BASIC, elle fonctionne indépendamment du lan- 
gage employé. Ainsi, les mêmes instructions VDU 
pourraient servir à un affichage graphique en 
PASCAL ou en tout autre langage offert sur le 
BBC. Toutes les possibilités graphiques en 
BASIC discutées jusqu'ici peuvent aussi être exé- 
cutées par l’instruction VDU appropriée. 


. 


quart de note {Li} au volume V20. Le tempo est 
fixé à T3: 
PLAY « T3L26;P4,03;V20;L1; LA # » 
<FADE (AT > 
silence 

En outre, on peut faire varier les paramètres T, 0, 
V et L de quantités fixées d’avance par l’instruc- 
tion, à l’aide d’un suffixe : 


Suffixe Effet 
+ ajoute 1 à la valeur en cours; 
— retranche 1 de la valeur en cours; 
< multiplie la valeur en cours’ par 2; 


> divise la valeur en cours par 2. 


Le format est : T+, T-, T> ou T< pour chaque 
paramètre. 

La meilleure possibilité du Dragon est de 
jouer des airs de musique en utilisant des « sous- 
chaînes ». Celles-ci sont définies avant d’être 
jouées dans n’importe quel ordre ou répétées : 


10 A$ = «FA:LA #;S0L» 
20 B$ = «DO;RÉ #:FA;P4:XA$:» 
30 PLAY B$ 


Ayant ainsi défini À, on l’inclut dans B$ sous la 
forme XA$. Voici l’air qui en résulte : do - ré #-fa 
- P4- fa - la # - sol. 

Cette technique peut être poursuivie si néces- 
saire lorsque des séquences de notes sont répé- 
tées un certain nombre de fois dans un morceau 
de musique. Dans tous les cas, il faut mettre un 
point-virgule après une sous-chaîne, comme en 
XA ci-dessus. 


Il est très facile de définir des caractères sur le 
Micro BBC. VOU contrôle cette fonction. Dans la 
section sur les graphiques définis par l’utilisa- 
teur, nous avons appris que les codes ASCII 
normaux sont construits à partir d’un bloc de 
8 X 8 pixels. Les pixels qui sont visibles peuvent 
être représentés par un 1 en binaire et les invisi- 
bles par un 0. Chaque rangée est alors convertie 
en son équivalent décimal; soit huit nombres 
décimaux pour définir un caractère. VDU 23 per- 
met à l’utilisateur de redéfinir ce caractère avec 
un code ASCII compris entre 224 et 255. Par 
exemple : 


10 REM DÉFINIR UN CARACTÈRE 

20 MODE 2 

30 VDU 23,240,16,56,124,146,16,16,16,0 
40 PRINT CHR$S(240) 

50 END 


Ce bref programme redéfinit le caractère de 
code ASCII 240 pour créer une forme de flèche. 
Les huit derniers nombres définissent cette nou- 
velle forme, et la ligne 40 affiche le caractère sur 
l’écran. En utilisant ces fonctions, les sorties 
graphiques et textes sur l’écran peuvent être 
limités à certaines zones définies. Cela est très 
utile dans le cas de programmes interactifs où il 
est souhaitable de partager l’écran. 


MODE 1 

Ce petit programine trace 
une fleur en spirales 
coloriées sur l'écran en 
utilisant la résolution en 
MODE 1. Noter l'utilisation de 
triangles colorés pour le 
dessin des pétales. 


10 REM FLEUR 

20 CLS 

30 MODE 1 

40 FOR D 1 103 

00 À = 600:B = 500 

60 MOVE AB 

10 FOR C = 1 TO 550 STEP 3 
80 GCOL/O,RND3} 

90 S = (C/RND(5I+10)) 
100 X = S'S*SINIC/161+A 
D Y « S'5"COSIC(61+B 
120 PLOT 65,xy 

130 NEXT C 

149 NEXT D 

150 END 


Le motif spiralé est 
produit par la combinaison 
de sinus et cosinus dans 
les lignes 100 et 110. 
Normalement, cette 
relation entre les 
coordonnées x et y produit 
un cercle, mais la boucle 
FOR..NEXT augmente 
progressivement le rayon 
C, et crée une spirale. Les 
coordonnées du centre de 
la spirale, À et B, peuvent 
être modifiées pour 
changer la position 

de la fleur. 


Passage d'essai 


Pour utiliser des fichiers de données, il faut d’abord les créer sous 
forme de canevas avant de les remplir avec des informations. 
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A la fin du dernier cours, nous avions laissé le 
lecteur face à cette impossibilité apparente : 
comment faire lire à un programme tournant 
pour la première fois un fichier qui n’existe pas 
(sur cassette ou sur disque)? La première fonc- 
tion que nous sommes en droit d’attendre du 
programme est que celui-ci lise-le fichier de don- 
nées et attribue ces données à des tableaux ou à 
des variables. Toutefois, si nous insistons 
d’abord sur l'écriture du fichier, nous devrons 
veiller, en programmant, à ne pas perdre toutes 
les données dans le fichier. Comme nous 
l’avons déjà constaté, si on tente d’ouvrir un 
fichier qui n’existe pas, soit cela ne fonction- 
nera absolument pas, soit le programme se 
« plantera » (arrêtera de fonctionner). 

Heureusement, il existe une solution simple. 
De nombreux logiciels commerciaux compor- 
tent un programme de « mise en route » que 
l’on doit faire marcher avant d’utiliser le pro- 
gramme principal; nous adopterons cette 
approche. Ces programmes permettent, en prin- 
cipe, de faire un certain nombre de modifica- 
tions (par exemple de choisir d’utiliser une 
imprimante Epson ou une Brother, parallèle ou 
série, etc.). 

Pour résoudre notre problème et permettre la 
procédure *LECFCR* (le programme qui lit dans le 
fichier et attribue les données aux tableaux), 
nous pouvons écrire un programme de « mise en 
route » simple qui ne fait qu’ouvrir un fichier et 
y écrire une valeur factice. Nous choisirons une 
valeur qui puisse être reconnue ensuite par le 
programme principal comme un enregistrement 
dont l’adresse n’est pas valide. Une valeur 
convenable serait la chaîne de caractères @PRE- 
MIER parce qu’aucun nom ni adresse, si obscure 
que soit son origine, n’a de chance de commen- 
cer par cette chaîne particulière. *LECFCR* devra 
être légèrement modifié afin que, lorsqu'il 
ouvre et lit le fichier, il vérifie sa valeur avant 
d’aller plus loin. Si votre ordinateur n’a pas le 
symbole @, vous pouvez le remplacer par ! ou 
par tout autre caractère qu’on ne rencontre nor- 
malement pas dans le registre d’adresses. Voici 
le programme de mise en route : 

10 REM CE PROGRAMME CRÉE UN FICHIER DE DONNÉES 

20 REM A UTILISER PAR LE PROGRAMME DE REGISTRE 
30 REM D'ADRESSES 
40 REM IL ÉCRIT UN ENREGISTREMENT FACTICE 
50 REM QUI PEUT ÊTRE UTILISÉ PAR *LECFCR* 
60 REM 
70 OPEN « 0 », #1, « ADBK.DAT » 
80 PRINT #1, « @PREMIER » 
90 CLOSE #1 
100 END 


Comme nous l’avons mentionné précédemment 
dans ce cours, les détails de lecture et d’écriture 
de fichiers diffèrent considérablement d’une 
version de BASIC à une autre, mais le principe 
est presque toujours le même. D’abord il faut 
ouvrir le fichier à l’aide de l’instruction OPEN 
avant de pouvoir l’utiliser pour des entrées ou 
des sorties. Ensuite, on indique le sens du flux 
de données (IN ou OUT). Puis on attribue un 
numéro de « canal » au fichier. Cela permet 
d’ouvrir et d’utiliser plusieurs fichiers à la fois 
(pour le moment, nous n’utiliserons qu’un seul 
fichier). Enfin, il faut déclarer le nom du fichier 
que nous voulons utiliser. 

La ligne 70 du programme est en BASIC 
Microsoft et elle est en principe semblable aux 
instructions OPEN utilisées par la plupart des 
BASIC. Bien entendu, OPEN déclare qu’un fichier 
doit être ouvert et 0 (« output ») indique que des 
données seront sorties. #1 est le numéro attri- 
bué au fichier pour cette opération; un autre 
numéro de fichier pourra être utilisé plus tard 
s’il le faut. ADBK.DAT est le nom que nous avons 
donné au fichier. 

La ligne 80 inscrit simplement un enregistre- 
ment dans le fichier. La syntaxe d’écriture de 
données dans un fichier est généralement (dans 
la plupart des BASIC) exactement la même que 
celle qui est utilisée pour PRINT, sinon que celle-ci 
doit être suivie du numéro de fichier — #1 dans 
le cas présent. 

La ligne 90 renferme le fichier. On peut lais- 
ser les fichiers ouverts aussi longtemps que 
l’exige le programme, maïs ils sont très vulné- 
rables et il faut les refermer dès que possible 
pour protéger les données qu’ils contiennent. 

Il règne une certaine confusion sur la manière 
dont les termes « enregistrement » et « fichier » 
sont utilisés en informatique. Cette confusion 
s’aggrave lorsqu'il est question de « bases » de 
données, d’une part, et de « fichiers » de don- 
nées, d’autre part. Dans une base de données, le 
fichier est un ensemble d’informations reliées 
entre elles. Par analogie, considérons un clas- 
seur de bureau : le fichier pourrait être un tiroir 
marqué « PERSONNEL ». Ce fichier comprend un 
enregistrement (une fiche dans une chemise) sur 
chaque personne de la société. Chaque enregis- 
trement (fiche) contient un certain nombre de 
zones, identiques pour chaque fiche, contenant 
des informations telles que « NOM », « SEXE », 
« AGE », « SALAIRE », « ANNÉES DE SERVICE », etc. 

Pour un fichier séquentiel sur disque ou sur 
cassette, la façon dont l’information est utili- 
sée ou organisée par le programme n’a pas 
d'importance. Les fichiers de données contien- 


nent simplement une série d’articles, dont cha- 
cun, pris individuellement, constitue un enregis- 
trement. Un seul enregistrement dans un fichier 
de données ne correspondrait donc pas à un 
enregistrement dans le sens de base de données. 

Le programme doit lire les enregistrements du 
fichier de données et les attribuer à des varia- 
bles, ou tableaux. Ceux-ci doivent être organi- 
sés pour former un enregistrement « concep- 
tuel » contenant un ensemble limité d’informa- 
tions. Il n’y a pas de relation biunivoque entre 
les enregistrements dans un fichier et ceux qui 

” comprennent une base de données. 

Une fois le programme de mise en route 
passé, on n’en aura plus jamais besoin. Si on le 
faisait repasser, il détruirait toutes les données 
« légitimes » qu’on aurait pu entrer dans la base 
de données du registre d’adresses. Nous allons 
voir pourquoi, en considérant le programme 
*LECFCR* modifié. 

Lorsque le programme tourne, il ne « sait » 
pas s’il y a des données légitimes ou non dans le 
fichier de données. La première chose que fasse 
*LECFCR* est d’ouvrir le fichier ADBK.DAT et d’y lire 
le premier enregistrement (ou article). Il ne 
s’agit pas de lire dans un élément de tableau, 
comme on pourrait le croire, mais dans une 
variable de chaîne particulière que nous avons 
appelée TEST$. Avant de lire tout autre enregis- 
trement, TESTS est vérifié pour voir s’il contient 
la chaîne @PREMIER. Si TESTS contient @PREMIER, le 
programme « sait » qu’il n’y a pas de données 
valables dans le fichier et qu’il n’y a donc pas 
lieu de continuer à lire. Par conséquent, on peut 
fermer le fichier et le reste du programme peut 

-se poursuivre. Puisqu’il n’y a pas de données 
valables dans le fichier, l’utilisateur ne peut rien 
faire de valable avant qu’au moins un enregis- 
trement n’ait été entré; la valeur de TEST$ peut 
donc également servir à obliger le programme à 
aller au sous-programme *AJOUTENR*, afin 
d’ajouter au moins un enregistrement valable. 

Si, en revanche, la valeur de TEST$ n’est pas 
@ PREMIER, le programme admet qu’il y a des 
données valables dans le fichier et il peut com- 
mencer à attribuer les données aux tableaux 
appropriés. 

Voici le sous-programme *LECFCR* modifié : 


1400 REM *LECFCR* SOUS-PROGRAMME 

1410 OPEN «1», #1, « ADBK.DAT » 

1420 INPUT # 1, TESTS 

1430 IF TESTS = « @PREMIER » THEN GOTO 1530: REM 
CLOSE AND RETURN 

1440 LET NOMCHPS(1) = TESTS 

1450 INPUT #1, MODCHP“(1), RUECHPS(1), VILCHPS(1), 
CPOCHP$(1), TELCHP$(1) 

1460 INPUT #1, NDXCHPS$ 

1470 LET TAILLE = 2 

1480 FOR L = 2 TO 50 

1490 INPUT #1, NOMCHPS(L), MODCHPS(L), RUECHP%(L), 
VILCHPS(L), CPOCHPS(L) 

1500 INPUT #1, TELCHP$(L), NDXCHPS(L) 

1510 REM ESPACE POUR APPELER SOUS-PROGRAMME 
« TAILLE » 

1520 NEXT L 

1530 CLOSE #1 

1540 RETURN 


La ligne 1420 assigne un seul enregistrement 
du fichier ADBK.DAT à la variable TEST$. La ligne 
suivante vérifie alors si cette valeur est @PRE- 


MIER. Si oui, l’instruction GOTO renvoie à la ligne 
1530 qui ferme le fichier, puis le sous-pro- 
gramme revient (RETURN) au programme princi- 
pal. Plus aucune tentative ne sera faite pour lire 
les données. En supposant qu’il n’y a pas de 
données valables dans le fichier, la commande 


x 


de programme sera ramenée à *INITIL* qui appelle 
alors *DEFDRA*. Tout ce que ce programme fait 
pour le moment est de fixer la grandeur à 1 si 
TESTS = @PREMIER. Le code pour *DEFDRA* est 
donné ci-dessous. 


1600 REM *DEFDRA"* 

1610 REM DÉFINIR DRAPEAUX APRÈS *LECFCR* 

1620 REM 

1630 REM 

1640 IF TESTS = «(@ PREMIER » THEN LET TAILLE = 0 
1650 REM 

1660 REM 

1670 REM 

1680 REM 

1690 RETURN 


Puis *DEFDRA* retourne à *INITIL* qui, à son tour, 
retourne au programme principal. *PROPRINC* 
appelle alors *ACCUEIL* qui affiche le message 
d’accueil. *ACCUEIL* ne nécessite aucune modifi- 
cation de la version précédemment publiée. 

Voici le programme *CHOIX* appelé par le pro- 
gramme principal. Une toute petite modifica- 
tion au sous-programme “CHOIX établira un 
moyen d’obliger l’utilisateur à ajouter un enre- 
gistrement si le programme tourne pour la pre- 
mière fois. 


3500 REM *CHOIX* SOUS-PROGRAMME 

3510 REM à 

3520 IF TESTS = « @PREMIER » THEN GOSUB 3860 

3530 IF TESTS = « @PREMIER » THEN RETURN 

3540 REM « CHEMENU » 

3550 -PRINT CHRS(12) 

3560 PRINT « SELECT UN DE SUITE » 

3570 PRINT 

3580 PRINT 

3590 PRINT 

3600 PRINT « 1. TROUVER ENREGISTREMENT (DE NOM) » 

3610 PRINT « 2. TROUVER NOMS (DE NOM INCOMPLET) » 
3620 PRINT « 3. TROUVER ENREGISTREMENT (DE VILLE) » 
3630 PRINT « 4. TROUVER ENREGISTREMENT (D'INITIALE) » 
3640 PRINT « 5. LIST TOUS ENREGISTREMENTS » 

3650 PRINT « 6. AJOUTER NOUVEAUX ENREGISTREMENTS » 
3660 PRINT « 7. CHANGER ENREGISTREMENT » 

3670 PRINT « 8. ENLEVER ENREGISTREMENT » 

3680 PRINT « 9. EXIT & SAVE » 


3690 PRINT 

3700 PRINT 

3710 REM « ENTRER CHOIX » 
3720 REM 

3730 LET L = O 

3740 LET 1 = 0 

3750 FOR L = OTO 1 

3760 PRINT « ENTRER CHOIX (1 — 9)» 
3770 FOR I = 1TO1 

3780 LET A$ = INKEY$ 

3790 IF A$ = « » THEN I = 0 
3800 NEXT I 


3810 LET CHOI = VAL(A$) 

3820 IF CHOI < 1 THEN L = O ELSE L = 1 

3830 IF CHOI > 9 THEN L = 0 

3840 NEXT L 

3850 RETURN 
Deux lignes ont été rajoutées. La première teste 
TEST$. Cette variable contient encore la valeur 
lue au cours du programme *LECFCR*. Si c’est 
@ PREMIER, nous savons qu’il n’y a pas de don- 
nées valables dans le fichier, et la seule option 
appropriée est donc AJOUTENR, dont le numéro 
est 6. Si le test est passé, la commande passe à 
*PREM*, sous-programme qui affiche un message 
approprié et fixe la variable CHOI à 6. Lorsque le 
sous-programme retourne à la ligne 3530, TESTS 
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est à nouveau testé (il est obligé de passer) et le 
sous-programme revient au programme princi- 
pal, en sautant le reste du sous-programme 
*CHOIX* puisqu’il ne convient pas. 

Vous vous êtes peut-être demandé pourquoi 
TESTS est testé deux fois. C’est pour éviter que le 
sous-programme ne retourne au mauvais 
endroit du programme. Sans la ligne 3530, le 
programme continuerait jusqu’au bout de 
*CHOIX*, en présentant un menu même s’il n’est 
pas nécessaire. Cela évite aussi d’utiliser GOTO, 
bien que IF TESTS = “ @PREM" THEN GOTO 3850 marche 
tout aussi bien. 

Avant de poursuivre avec *PREM*, le lecteur se 
reportera à *LECFCR* et au GOTO de la ligne 1430. 
Puisque nous avons contesté l’usage de GOTO, 
pourquoi l’avoir utilisé ici? 41 aurait été très 
facile de fermer (CLOSE) le fichier et de revenir au 
programme principal (RETURN) en testant simple- 
ment la valeur de TESTS en deux lignes distinctes. 
Mais nous avons utilisé ici GOTO pour illustrer un 
des quelques exemples où son usage est excu- 
sable : à l’intérieur d’un segment de programme 
très court et identifiable, et sa fonction est évi- 
dente (d’autant plus qu’elle est commentée par 
REM). GOTO ne doit jamais être utilisé pour sortir 
d’une boucle (cela peut laisser la valeur des 
variables dans un état indéterminé), ni d’un 
sous-programme (sous peine d’embrouiller 
l'instruction RETURN, à moins de rajouter une 
instruction pour retourner dans le sous- 
programme), ni pour aller vers des parties trop 
éloignées du programme (ce qui rend le pro- 
gramme impossible à suivre). 

Le sous-programme *PREM* est simple et direct : 
l’écran est effacé et un message s’affiche pour 
informer l’utilisateur qu’un enregistrement doit 
être entré. La ligne 3870 donne à CHOI la valeur 6 
afin que le programme *AJOUTENR* soit exécuté 
automatiquement lorsqu’on repasse le contrôle 
à *EXECUT*. 

Le code pour “PREM* est le suivant : 


3860 REM *PREM* SOUS-PROGRAMME (AFFICHE 
MESSAGE) 

3870 LET CHOI = 6 

3880 PRINT CHR$(12): REM EFFACER ÉCRAN 

3890 PRINT 

3900 PRINT TAB(8): « PAS D'ENREGISTREMENTS DANS » 

3910 PRINT TAB(8): « LE FICHIER: VOUS AUREZA 

3920 PRINT TAB(6): « COMMENCER PAR AJOUTER 
ENREGISTREMENT » 

3930 PRINT 

3940 PRINT TAB(5): « (APPPUYER BARRE-ESPACE POUR 
CONTINUER) 

3950 FOR B = 1TO 1 

3960 IF INKEY$ < >« » THEN B = 0 

3970 NEXT B 

3980 PRINT CHR4(12): REM EFFACER ÉCRAN 

3990 RETURN 


Le sous-programme *AJOUTENR* comporte deux 
modifications légères mais importantes par rap- 
port à la version rencontrée précédemment. 
Après avoir entré les zones en tant qu’éléments 
dans les différents tableaux, on incrémente la 
variable TAILLE et on donne à TEST$ une valeur 
nulle (voir lignes 10090 et 10100). TAILLE est une 
variable importante utilisée dans différentes 
parties du programme, de sorte qu’elle « sait » 
sur quels enregistrements on est en train de tra- 
vailler. A l’origine, on avait posé TAILLE - O0 en 


tant que partie du sous-programme *CRETAB*. 
Ensuite, dans *DEFDRA*, il est fixé à 1 si TESTS = 
« @ PREMIER ». Ainsi, la première fois que l’on 
exécute *AJOUTENR*, les instructions d’entrée 
mettront les données dans le premier élément 
de chaque tableau. En d’autres termes, INPUT 
« ENTRER NOM »; NOMCHPS (TAILLE) est équivalent à 
INPUT « ENTRER NOM »; NOMCHPS(1). 

La ligne 10090 incrémente TAILLE qui est main- 
tenant égal à 2. Si *AJOUTENR* est à nouveau exé- 
cuté, les données seront entrées dans le second 
élément de chaque tableau. Finalement *AJOU- 
TENR* fixe TESTS à « » à la ligne 10100. Cela a 
lieu parce qu’un enregistrement est entré (quoi- 
que non encore stocké dans le fichier de don- 
nées sur bande ou disque). Si l’on exécute à 
nouveau *CHOIX*, comme il faut le faire pour 
sauvegarder les données et sortir du pro- 
gramme, nous ne voulons pas être forcés 
d’ajouter un nouvel enregistrement. Si TESTS 
n’était pas remis à zéro, le programme serait 
pris dans une boucle sans fin. Le seul moyen 
d’en sortir serait de faire RESET ou de débrancher 
l’ordinateur. Les données seraient perdues. 

En posant TEST$ égal à une chaîne nulle, les 
tests des lignes 3520 et 3530 de *CHOIX* ne réussis- 
sent pas et permettent l’affichage du menu. Ce 
qui arrive alors à TAILLE dépend du programme 
exécuté. Jusqu’à présent nous avons posé que 
TAILLE = 1 s’il n’y a pas de données valables dans 
le fichier, et que sa valeur est incrémentée de 1 
chaque fois qu’on ajoute un enregistrement. 
Mais que se passerait-il s’il y avait un certain 
nombre d’enregistrements valables dans le 
fichier ? Pour le savoir, reconsidérons *LECFCR*. 

La ligne 1420 lit la première donnée dans 
TESTS. Si ce n’est pas @PREMIER, il est admis 
qu’elle est valable. Les enregistrements dans le 
fichier suivent toujours le même ordre : NOMCHP, 
MODCHP, RUECHP, VILCHP, CPOCHP, TELCHP, NDXCHP, 
NOMCHP, MODCHP, et ainsi de suite. Si le premier 
enregistrement lu est une donnée valable, elle 
doit faire partie du premier élément du tableau 
NOMCHP$, donc la ligne 1440 transfère cette don- 
née de TESTS à NOMCHPS${1). Les deux lignes suivan- 
tes remplissent les cinq autres tableaux. Nous 
savons que nous avons au moins un enregistre- 
ment complet (base de donnée), donc on pose 
TAILLE = 2. Cette valeur doit être supérieure au 
nombre d’enregistrements valables lus dans les 
tableaux, sinon *AJOUTENR* écrirait de nouvelles 
données dans des éléments qui contiennent déjà 
des données valables. 

Ensuite, une boucle de 2 à 50 lit les enregistre- 
ments dans les six tableaux, incrémentant 
l’indice L à chaque passage. Nous avons décidé 
de restreindre notre programme à des fichiers de 
cinquante noms et adresses, et les instructions 
DIM dans le sous-programme *CRETAB* ont prévu 
cet espace. À la première utilisation du pro- 
gramme, il est peu probable que l’on dispose 
d’un fichier complet de cinquante articles. Il 
faudra donc prévoir un sous-programme qui 
puisse détecter cela le cas échéant, fixer la 
valeur de TAILLE en conséquence et sortir de la 
boucle de lecture. 
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Nous avons donc inclus la ligne 1510 pour 
appeler un sous-programme ‘TAILLE que nous 
expliciterons ultérieurement. Il y a trois façons 
d’aborder ce problème. Premièrement, lorsque 
nous écrivons la donnée sur la bande, nous 
pourrions faire en sorte que le premier enregis- 
trement écrit soit la variable TAILLE. Le sous- 
programme *LECFCR* peut alors être modifié 
pour lire d’abord TAILLE avant d’entrer dans une 
boucle de la forme FOR L = 1 TO TAILLE pour lire les 
enregistrements. Deuxièmement, on ne com- 
mence la procédure que lorsque tous les enre- 
gistrements ont été écrits et terminés par un 
indicateur spécial (peut-être de la forme @ END). 
Cette méthode est préférable car elle ne se 
heurte pas à notre précédent test @PREMIER à la 
ligne 1430. On peut ensuite faire un test dans 
*LECFCR* pour sortir de la boucle lorsqu’on ren- 
contre @END. Troisièmement, on peut faire 
usage de la fonction EOF (fin de fichier) existant 
sur certains ordinateurs, qui consiste en une ver- 
sion automatisée de la deuxième méthode. Ces 
ordinateurs ont un indicateur d’E0F qui a nor- 
malement la valeur D, c’est-à-dire « faux », et 
parfoisuneautre valeur, généralement 1 («vrai»), 
lorsque la fin du fichier est atteinte. Certains 
BASIC permettent de tester l’indicateur EOF 
comme s’il s’agissait d’une variable BASIC; dans 
ce cas, une construction de la forme : 


TANT QUE EOFIN) N’EST PAS VRAI IN est le numéro de 
fichier) 
DO. 
INPUT #N, données à lire 
FIN 


résoudra le problème. Sur d’autres machines, 
EOF est représenté comme un simple bit auquel 
on accède par l’instruction PEEK. Pour trouver si 
votre machine possède une fonction E0F, vous 
devez consulter le manuel d’instructions.. 


Le sous-programme *EXECUT* ne devrait norma- 
lement pas avoir la ligne 4019 (d’où ce numéro 
de ligne particulier), la ligne 4020 devrait être : 


ON CHOI GOSUB numéro, numéro, numéro, etc 
ou une série de : 


IF CHOI = 1 THEN GOSUB numéro 
IF CHOI = 2 THEN GOSUB numéro, etc. 


La ligne 4019 permet de faire tourner le pro- 
gramme même si les autres sous-programmes 
EXECUT n’ont pas encore été codés. 


10 REM « PROG PRINCIPAL » 
20 REM ‘INITIL* 

30 GOSUB 1000 

40 REM *ACCUEIL* 

50 GOSUB 3000 

60 REM “CHOIX” 

70 GOSUB 3500 

80 REM *EXECUTE* 

90 GOSUB 4000 

100 END 


1000 REM ‘INITIL* SOUS-PROGRAMME , 

1010 GOSUB 1100: REM *CRETAB* SOUS-PROGRAMME (CRÉER 
TABLEAUX) 

1020 GOSUB 1400: REM *LECFCR* SOUS-PROGRAMME (LECTURE 
FICHIER) 

1030 GOSUB 1600: REM *DEFDRA* SOUS-PROGRAMME (VALIDATION 
DRAPEAUX) 

1040 REM 

1050 REM 

1060 REM 

1070 REM 

1080 REM 

1090 RETURN 


1100 REM *CRETAB* SOUS-PROGRAMME (CREER TABLEAUX) 
1110 DIM NOMCHPS$ 
1120 DIM MODCHPS 
1130 DIM VILCHP$ 
1140 DIM CPOCHP$ 
1150 DIM TELCHP$ 
1160 DIM NDXCHP$ 
1170 REM 

1180 REM 

1190 REM 

1200 REM 

1210 LET TAILLE = © 
1220 LET RMOD = 0 
1230 LET SVED = 0 
1240 LET ACT = O0 
1250 REM 

1260 REM 

1270 REM 

1280 REM 

1290 REM 

1300 RETURN 


10000 REM SOUS-PROGRAMME * AJOUTENR 

10010 PRINT CHR$(12): REM EFFACER ÉCRAN 

10020 INPUT « ENTRER NOM » : NOMCHPS(TAILLE) 

10030 INPUT « ENTRER RUE » ; RUECHPS(TAILLE) 

10040 INPUT « ENTRER VILLE »: VILCHPS(TAILLE) 

10050 INPUT « ENTRER CODE POSTAL » ; CPOCHPS(TAILLE) 
10060 INPUT « ENTRER NUMÉRO TÉLÉPHONE » : TELCHPS(TAILLE) 
10070 LET RMOD = 1: REM INDICATEUR ARTICLE MODIFIÉ 
10080 LET NDXCHPS(TAILLE) = RUECHPS(TAILLE) 

10090 LET TAILLE = TAILLE + 1 

10100 LET TESTS = « » 

10110 REM INSÉRER ICI APPEL DE *MODNOM* 

10120 REM 

10130 REM 

10140 REM 

10150 RETURN 


Variantes de basic 


M Étant donné que le Spectrüm a la 
possibilité de sauvegarder ou de 
charger des tableaux entiers à l’aide 
| de l'instruction  SAVEDATA, le sous- 
EE programme LECFCR sera complètement 
différent. Lorsque nous 
commencerons à écrire les données, 
nous publierons une version 
complète des sous-programmes 
correspondant à cette machine. 

En attendant, à titre d'exercice, ceux 
qui possèdent un Spectrum peuvent 
s'attaquer au problème qui consiste 
à créer le fichier factice contenant 

@ PREMIER ; il faut également 
déterminer combien il y a d'articles 
valables dans le tableau, en lisant 

le fichier. 


! Voir « Variantes de basic ». 
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Tony Lodge 


James Powers 

Les machines de Powers 
étaient destinées à une 
seule application. Il s'est 
néanmoins révélé un rival 
sérieux d'Hollerith. 


Hermann Hollerith 
Hollerith inventa la 

« liseuse » de cartes 
électromécanique qui 
devint plus tard la machine 
à cartes ou tabulatrice. 

(CI. IBM.) 
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Jeux de cartes 


Hermann Hollerith et James 
Powers ont tous les deux 
développé des machines à cartes 
perforées. Leur rivalité dura 

six décennies. 


Les machines que Hermann Hollerith inventa 
pour dépouiller les résultats du recensement de 
1890 aux Etats-Unis évoluèrent vers une gamme 
d’appareils de traitement d’informations à utili- 
sations variées, connus sous le nom de « machi- 
nes à cartes perforées » ou « tabulatrices ». 
Jusqu’à l’apparition des premiers ordinateurs 
commerciaux dans les années cinquante, les 
machines à cartes perforées favorisèrent le déve- 
loppement de l’industrie et des affaires. A Pitts- 
burgh, dans les années trente, un grand magasin 
expérimenta un système de comptes clients pour 
lequel deux cent cinquante terminaux disposés 
partout dans le magasin étaient reliés par lignes 
téléphoniques à des tabulatrices regroupées 
dans une même pièce. Le prix des marchan- 
dises était écrit sur des étiquettes perforées, et 
cette information était envoyée automatique- 
ment aux tabulatrices qui ensuite enregistraient 
la vente et préparaient une facture pour le 
client, après diverses vérifications. 

En fait, la concurrence dans les affaires a 
favorisé le développement des tabulatrices. 
L’exclusivité dont jouissait Hollerith pour la 
fourniture des équipements électromécaniques 
destinés au service de recensement poussa 
James Powers à fournir d’autres machines. 
Powers proposa un système de tabulatrices 
entièrement mécaniques. La rivalité entre les 
deux hommes, puis entre les deux sociétés qu’ils 


Les machines à cartes 


A leur apogée, dans les années cinquante, ces 
machines comprenaient huit unités différentes. 

Les données étaient mises sur carte à l’aide d’une 

« perforatrice » qui pouvait traiter deux cents cartes 

à l'heure. Une « vérificatrice » contrôlait les fautes 

de frappe, et lorsque les cartes vieillissaient, 

une reproductrice en perforait de nouvelles. 

La tabulatrice, elle, accumulait les totaux des données 
chiffrées dans les colonnes et sortait les résultats à 
une cadence de neuf mille cartes à l'heure. Cette 
tabulatrice était souvent reliée à une calculatrice 
mécanique qui fournissait des fonctions 
mathématiques plus complexes. L’« interclasseuse » 
avait pour tâche de comparer les informations 
contenues dans deux paquets de cartes perforées ou 
de regrouper les paquets. Enfin, la « trieuse » pouvait 
ventiler le paquet de cartes en treize piles différentes 
— une pile pour chacune des douze perforations et une 
pile pour les colonnes vierges. 

Le fonctionnement de la tabulatrice était commandé 
par des caractères de contrôle dans les positions 11 
et 12. Les cartes de contrôle étaient de couleur vive 
pour être facilement repérables dans une pile. Lorsque 
la tabulatrice rencontrait une carte de contrôle, elle 
commençait une nouvelle opération : par exemple, elle 
se mettait à compter dans une zone différente. 

(CI. BBC Hulton.) 


créèrent par la suite, stimula la croissance de 
machines de traitement de l’information. 

En 1902, Hollerith dessina un tableau de 
connexions (ressemblant aux premiers stan- 
dards téléphoniques) permettant de choisir les 
colonnes de la carte perforée à additionner et à 
sortir. Ainsi, la machine de Hollerith avait une 
possibilité de programmation qui faisait défaut 
aux machines inventées par son rival. En 1924, 
Powers fit breveter une méthode de représenta- 
tion des données alphanumériques sur une carte 
perforée utilisant une seule perforation dans 
chaque colonne pour représenter un nombre et 
une combinaison de perforations pour représen- 
ter une lettre. Hollerith réagit rapidement en 
créant son propre système, la carte standard à 
quatre-vingts colonnes. Chaque colonne de 
cette carte comprenait douze lignes de perfora- 
tions « lues » par des balais métalliques dont le 
contact avec une plaque de métal située sous la 
carte fermait un circuit électrique. Certains 
systèmes plus modernes utilisaient une cellule 
photoélectrique au lieu d’un balai. 

Les premières tabulatrices servaient unique- 
ment à compter ou à additionner, mais plus tard 
elles furent dotées de fonctions mathématiques 
plus avancées permettant de traiter les données. 
D’autres applications de ces nouvelles machines 
sont vite apparues. Des tabulatrices spéciales 
furent créées pour l’utilisation des tables de cal- 
cul, pour l’analyse des ondes et pour l’astrono- 
mie — ce sont des tabulatrices qui ont permis 
d’identifier Pluton en 1930. Les tabulatrices 
devinrent finalement suffisamment sophisti- 
quées pour traiter en chaîne de grandes masses 
de données — IBM en a fait breveter une qui 
pouvait suivre les mouvements de dix mille 
comptes en banque. 


PROGRAMME 


N° 8 


JEU DE DÉS 


Nous avons déjà abordé le rôle des fonctions 
RND et INT. 

Utilisons à nouveau ces instructions et mêlons- 
les au graphique. Pour cela, nous allons simuler 
le jet de deux dés : un bleu et un vert. 

Tapez le programme suivant : 


S HOME 

1@ PRINT "SIMULATION D'UNE PAIRE DE DES" 
20 PRINT PRINT PRINT "DE BLEU :", 

38 PRINT INT CE* RND (13 + 1) 


48 PRINT PRINT PRINT "DE VERT :"; 
SA PRINT INT €C6G*X RND (1) + 1) 

EG END 

SRUN 


SIMULATION D’UNE PAIRE DE DES 


DE BLEU 3: 1 
DE VERT : 5 
SRUN 


SIMULATION D'UNE PAIRE DE DES 


DE BLEU : 4 
DE VERT : 4 
SRUN 


SIMULATION D’UNE PAIRE DE DES 


DE BLEU : 6 
DE VERT : & 
SRUN 


SIMULATION D’UNE PAIRE DE DES 


DE BLEU : 5 


DE VERT : 5 


En 10, le titre. 

En 20, deux sauts de ligne : ? : ? : et on fait écrire 
à la machine (« DE BLEU ». 

En 30 ? INT (6 * RND {1} + 1). 


RND génère un nombre décimal aléatoire compris 
entre 0 et 1. Je multiplie ce nombre par 6 et j’y 
ajoute 1 (pour un dé, le 0 est une valeur qui ne 
convient pas). Enfin, je prends la partie entière 
(INT) du nombre généré. 

Lignes 40 et 50, mêmes choses pour le dé vert. 


ORGANIGRAMME 


DÉBUT 


ON GÉNÈRE LA VALEUR DU 
« DE BLEU » 


INT (6 * RND [1] + 1) 


ON GÉNÈRE LA VALEUR DU 
« DE VERT » 


INT (6 * RND 1) + 1) 


Supprimons la ligne 60 et ajoutons une petite 
conclusion à ce programme grâce à un test 
IF … THEN. 

Tout d’abord, affectons un nom A et B aux 
deux valeurs affichées par les dés. 

Tapez alors : 


D. Le Goff - SI 


Programmes 


SLIST 


5 HOME 
19 PRINT "SIMULATION D'UNE PAIRE DE DES" 
2@ PRINT : PRINT : PRINT "DE BLEU :", 
25 A = INT (E* RND (19 + 1) 
30 ? A 
4@ PRINT : PRINT : PRINT "DE VERT :", 
45 B = INT (6% RND C1) + 1) 
5 ?8B 
EE S=mfe D 1: 7 5 ? 
7@ IF S = 12 THEN FLASH : 
? "VOUS AVEZ GAGNE 100 $ 
RECOMMENCEZ !" 1: 
NORMAL : GOTO 10 
80 IF S>9 AND S<12 THEN FLASH : 
? MRIEN GAGNE, MAIS RECOMMENCEZ !" 
NORMAL : GOTO 10 
90 FLASH : ? “PERDU... PERDU. .. PERDU. .." 
189 ? "AU REVOIR ET MERCI" : NORMAL 
119 END 
L'ORGANIGRAMME 


EST LE SUIVANT : 


ON GÉNÈRE LA VALEUR DU 
« DE BLEU » 

ON GÉNÈRE LA VALEUR DU 
« DE VERT » 


s<S< 12 


RIEN GAGNÉ GAGNE 100 $ 
MAIS RECOMMENCEZ RECOMMENCEZ 


AUTRE VALEUR DE S 


PERDU, AU REVOIR 
ET MERCI 


KALÉIDOSCOPE 


Lions tout ceci au graphique et créons des 
points de couleur d’une manière aléatoire. 


SLIST 

18 HOME 

28 GR 

30 REM CREATION D'UNE COULEUR ALEATOIRE 
49 COLOR = INT (16)* RND (1) 

SQ REM CREATION D'UN POINT ALEATOIRE 
ES X = INT C4@* RND (13) 

78 Y = INT (48% RND (13) 

88 REM TRACAGE DU POINT 

98 PLOT X Y 

109 REM RENCORE 

119 GOTO 49 


40 génère une couleur d’une manière aléatoire. 
INT 116} * RND (1 + 1 


génère un nombre aléatoire compris entre 0 et 1 
qui est multiplié par 16 dont on prend la partie 
entière. 

60 et 70 génèrent les coordonnées d’un point (X 
et Y) d’une manière aléatoire. 


Rappel : l’écran GR (40 col., 40 lignes) 
90 trace le point 
110 on recommence 
Stoppez l’exécution par CTRL - € RETURN simulta- 
nément. 


ORGANIGRAMME 


ON GÉNÈRE LA COULEUR 


ON _. 
puis 
à 


TRAÇONS LE POINT 
DE COORDONNÉES 


X et Y 


